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Bubble Sort 

Sorting activities for Bubble: 

• Go through multiple passes over the array. 

• In every pass: 

- Compare adjacent elements in the list. 

- Exchange the elements if they are out of order. 

- Each pass moves the largest (or smallest) elements to the 
end of the array 

• Repeating this process in several passes eventually sorts the 
array into ascending (or descending) order. 

• Bubble sort complexity is is 0(n 2 ) and only suitable to sort 
array with small size of data. 
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Bubble Sort 




// Sorts items in an array into ascending order, 
void BubbleSort(dataType data[], int listSize) 
{ int pass, tempValue; 
for ( pass =l;pass < listSize; pass++ ) 

{ 

// moves the largest element to the 
// end of the array 
for (int x = 0; x < listSize - pass; x++) 
//compare adjacent elements 
if ( data[x]>data[x+l] ) 
{ // swap elements 
tempValue = data[x]; 
data[x] = data[x+l]; 
data[x+l] = tempValue; 

} 

} 

}//end Bubble Sort 
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Implementation 



External for loop is used to control 
the number of passes needed. 



Internal for loop is used to compare 
adjacent elements and swap 
elements if they are not in order. 
After the internal loop has finished 
execution, the largest element in the 
array will be moved at the top. 

if statement is used to compare the 
adjacent elements. 
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Sort [783 16] into Ascending Order 



pass = 1 



List Size = 5 




no swap swap(8,3) swap(8,1) swap (8,6) 
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Sort [783 16] into Ascending 

Order 



pass = 2 



listSize = 5 




swap(7,3) swap(7,1) swap (7,6) 
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Sort [783 16] into Ascending Order 



pass= 3 
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Sort [783 16] 
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pass = 4 
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Bubble Sort Analysis 



• The number of comparison between elements and the 
number of exchange between elements determine the 
efficiency of Bubble Sort algorithm. 

• Generally, the number of comparisons between elements 
in Bubble Sort can be stated as follows: 

(n-l) + (n-2) + +2 + 1= n(n-l)/2 = 0(n 2 ) 





Bubble Sort Analysis [783 16] 




Pass 1 : Comparison (listSize-pass=4) Pass 2 : Comparisons (listSize-pass: (5-2=3)) 






(n-l) + (n-2) + +2 + 1= n(n-l)/2 = 0(n 2 ) 

The number of comparisons: 

(5-1) + (5-2) + (5-3) + (5-4) = 4 + 3 + 2 + 1 = 10. 




(£)©©© 


Inspiring Creative and Innovative Minds 


ocw.utm.my 




Pass 3 : Comparison (5-3= 2) Pass 4 : Comparisons (5-4=1) 





The number of comparisons to sort data in this list: 

(5-1) + (5-2) + (5-3) + (5-4) = 4 + 3 + 2 + 1 = 10. 
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Pass 3 : Comparison (5-3= 2) Pass 4 : Comparisons (5-4=1) 





The number of comparisons to sort data in this list: 

(5-1) + (5-2) + (5-3) + (5-4) = 4 + 3 + 2 + 1 = 10. 
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Bubble Sort Analysis 



In any cases, (worse case, best case or average case) 
to sort the list in ascending order the number of 
comparisons between elements is the same. 

Worse Case [8763 1] 
Average Case [783 16] 
Best Case [13 6 7 8] 

All lists with 5 elements need 10 comparisons to sort 
all the data. 
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Bubble Sort Analysis 

In the example given, it can be seen that the number of 
comparison for worse case and best case is the same - with 10 
comparisons. 

The difference can be seen in the number of swapping 
elements. Worse case has maximum number of swapping: 
10, while best case has no swapping since all data is already in 
the right position. 

For best case, starting with pass one, there is no exchange of 
data occur. 

From the example, it can be concluded that in any pass, if 
there is no exchange of data occur, the list is already sorted. 
The next pass shouldn't be continued and the sorting process 
should stop. 
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mproved B 



// Improved Bubble Sort 

// Sorts items in an array into ascending order. 

void bubbleSort(DataType data[], int n) 
{ int temp; 

bool sorted = false; // false when swaps occur 
for (int pass = 1 ; (pass < n) && ! sorted; ++pass] 
{ sorted = true; // assume sorted 
for (int x = 0; x < n-pass; ++x) 
{ if (data[x]>data[x+1]) 
{ // exchange items 
temp = data[x]; 
data[x] = data[x+1]; 
data[x+1] = temp; 
sorted = false; // signal exchange 
} // end if 
} // end for 
} // end for 
} // end bubbleSort 
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ubble Sort 




To improve the efficiency of Bubble 
Sort, a condition that check whether 
the list is sorted should be add at the 
external loop 

A Boolean variable, sorted is 
added in the algorithm to signa 
whether there is any exchange 
of elements occur in certain 
pass. 

In external loop, sorted is set 
to true. If there is exchange 
of data inside the inner loop, 
sorted is set to false. 

Another pass will continue, if 
sorted is false and will stop if 
sorted is true. 





Improved Bubble Sort : Best Case[l 3 6 7 8] 




In pass 1 , there is no exchange of data occur and variable sorted is 
always True. 

Therefore, condition statement in external loop will become false and the 
loop will stop execution. In this example, pass 2 will not be continued. 



Analysis - For best case, the number of comparison between 
elements is 4, (n-1) which is O(n). 
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Improved Bubble Sort : 
Average Case [13 7 6 8] 




sorted = T 



For Average Case: 

• [1 3 7 6 8] we have to go 
through 2 passes only. The 
subsequent passes is not 
continued since the array is 
already sorted. 



pass = 1 



Conclusion - For improved 
Bubble Sort, the sorting time 
and the number of 
comparisons between data in 
average case and best case 
can be minimized. 




ocw.utm.my ^ UTM 

Bubble Sort - Algorithm Complexity 

• Complexity is measured based on time consuming 
operations to compare and swap elements. 

• Number of comparisons 

- a for loop embedded inside a while loop 

- Worst Case (n-l)+(n-2)+(n-3) ...+1 , or 0(n 2 ) 

- Best Case - (n-1) or O(n) 

• Number of Swaps 

- inside a conditional -> #swaps data dependent ! ! 

- Best Case 0, or 0(1) 

- Worst Case (n-l)+(n-2)+(n-3) ...+1 , or 0(n 2 ) 
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Summary and Conclusion 

Bubble Sort takes several passes to sort elements in 
an array. Every pass need to do comparisons between 
elements and exchange the data if the elements are 
not in the right order. However the complexity of 
Bubble sort is the same for best case and worse case. 
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0(rf) 


0 


Average 
Case 
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Worst Case 
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0(A7 2 ) 
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